package jsp;

import util.CookieUtil;
import util.StringUtil;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.sql.*;

/**
 * @author Miss Chen
 * @version 1.0
 * @date 2024年09月03日15:16
 */

/**
 * 用户在访问该servlet
 * 当用户访问该servlet时候，会对当前Cookie中的数据进行检查
 * 判断当前Cookie中是否包含username和password
 * 如果存在
 * 则判断当前的username与password是否正确
 *      如果正确
 *          则直接进入主页main.jsp
 *      如果不正确
 *          移除当前Cookie中保存的username与password
 *          则进入登录页面login.jsp，需要用户进行登录
*  如果不存在，则进入登录页面login.jsp.需要用户进行登录
 */

@WebServlet("/showMain")
public class ShowMainServlet extends HttpServlet {
    @Override
    protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //去除Cookie中的数据
        String username= CookieUtil.findByName("username",request);
        String password=CookieUtil.findByName("password",request);

        //如果Cookie中没有取到对应数据，直接跳转到登录页面
        if(StringUtil.isNull(username) ||StringUtil.isNull(password)){
            request.getRequestDispatcher("/jsp/login.jsp").forward(request,response);
            return;
        }
        Connection conn=null;
        PreparedStatement ps=null;
        ResultSet rs=null;
        String url="jdbc:mysql://127.0.0.1:3306/jdbc?useUnicode=true&characterEncoding=utf-8";
        try {
            Class.forName("com.mysql.jdbc.Driver");
            conn= DriverManager.getConnection(url,"root","root");
            String sql=new StringBuffer()
                    .append(" select id,username,password ")
                    .append(" from t_user ")
                    .append(" where username=?  ")
                    .append(" and password=? ")
                    .toString();
            ps=conn.prepareStatement(sql);
            ps.setString(1,username);
            ps.setString(2,password);
            rs=ps.executeQuery();
            if(rs.next()){
                //登录成功之后页面跳转到主页
                request.getRequestDispatcher("/jsp/main.jsp").forward(request,response);
                return;
            }

            //如果cookie中的用户名密码和数据库不一致，说明当前保存在cookie中的数据被删除
            CookieUtil.deleteCookie("username",response);
            CookieUtil.deleteCookie("password",response);
            //登录失败后转到到登录页面
            request.getRequestDispatcher("/jsp/login.jsp").forward(request,response);

        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        }finally {
            // 关闭释放资源
        }





    }
}
